<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<link rel="stylesheet" href="${ctx}/resources/layui/css/layui.css">
<link rel="stylesheet" href="${ctx}/resources/layui_ext/dtree/dtree.css">
<link rel="stylesheet" href="${ctx}/resources/layui_ext/dtree/font/dtreefont.css">
</head>
<body>
	<!-- 搜索条件开始 -->
	<fieldset class="layui-elem-field layui-field-title" style="margin-top: 20px;">
	  <legend>查询条件</legend>
	</fieldset>
	<form class="layui-form" method="post" id="searchFrm">
		<div class="layui-form-item">
		    <div class="layui-inline">
		      <label class="layui-form-label">用户姓名:</label>
		      <div class="layui-input-inline">
		        <input type="text" name="realname"  autocomplete="off" class="layui-input">
		      </div>
		    </div>
		    <div class="layui-inline">
		      <label class="layui-form-label">登陆名称:</label>
		      <div class="layui-input-inline">
		        <input type="text" name="loginname"  autocomplete="off" class="layui-input">
		      </div>
		    </div>
		    <div class="layui-inline">
		      <label class="layui-form-label">用户地址:</label>
		      <div class="layui-input-inline">
		        <input type="text" name="address"  autocomplete="off" class="layui-input">
		      </div>
		    </div>
		 </div>
		 
		 <div class="layui-form-item">
		    <div class="layui-inline">
		      <label class="layui-form-label">用户电话:</label>
		      <div class="layui-input-inline">
		        <input type="text" name="phone"  autocomplete="off" class="layui-input">
		      </div>
		    </div>
		    <div class="layui-inline">
		      <label class="layui-form-label">身份证号:</label>
		      <div class="layui-input-inline">
		        <input type="text" name="identity"  autocomplete="off" class="layui-input">
		      </div>
		    </div>
		     <div class="layui-inline">
		      <label class="layui-form-label">性别:</label>
		      <div class="layui-input-inline">
	       		 <input type="radio" name="sex" value="1" title="男">
				 <input type="radio" name="sex" value="0" title="女">
		      </div>
		    </div>
		 </div>
		 <div  class="layui-form-item" style="text-align: center;">
		  <div class="layui-input-block" >
		      <button type="button" class="layui-btn layui-btn-normal  layui-icon layui-icon-search" id="doSearch">查询</button>
		      <button type="reset" class="layui-btn layui-btn-warm  layui-icon layui-icon-refresh">重置</button>
		    </div>
		 </div>
	</form>
	
	<!-- 搜索条件结束 -->
	
	
	<!-- 数据表格开始 -->
	<table class="layui-hide" id="menuTable" lay-filter="menuTable"></table>
	<div style="display: none;" id="menuToolBar">
		    <button type="button" class="layui-btn layui-btn-sm" lay-event="add">增加</button>
		    <button type="button" class="layui-btn layui-btn-warm layui-btn-sm" lay-event="batchDelete">批量删除</button>
	</div>
	<div  id="userBar" style="display: none;">
	  <a class="layui-btn layui-btn-xs" lay-event="edit">编辑</a>
	  <a class="layui-btn layui-btn-warm layui-btn-xs" lay-event="resetUserPwd">重置密码</a>
	  <a class="layui-btn layui-btn-danger layui-btn-xs" lay-event="del">删除</a>
	  <a class="layui-btn layui-btn-warm layui-btn-xs" lay-event="selectUserRole">分配角色</a>
	</div>
	<!-- 数据表格结束 -->
	
	<!-- 添加和修改的弹出层开始 -->
	<div style="display: none;padding: 20px" id="saveOrUpdateDiv" >
		<form class="layui-form"  lay-filter="dataFrm" id="dataFrm">
			<div class="layui-form-item">
				<div class="layui-inline">
					<label class="layui-form-label">用户姓名:</label>
					<div class="layui-input-inline">
						<input type="hidden" name="userid">
						<input type="text" name="realname" lay-verify="required"   placeholder="请输入用户姓名" autocomplete="off"
							class="layui-input">
					</div>
				</div>
				<div class="layui-inline">
					<label class="layui-form-label">登陆名称:</label>
					<div class="layui-input-inline">
						<input type="text" name="loginname" lay-verify="required"  placeholder="请输入用户登陆名称" autocomplete="off"
							class="layui-input">
					</div>
				</div>
			</div>
			<div class="layui-form-item">
				<div class="layui-inline">
					<label class="layui-form-label">身份证号:</label>
					<div class="layui-input-inline">
						<input type="text" name="identity"  placeholder="请输入用户身份证号" autocomplete="off"
							class="layui-input">
					</div>
				</div>
				<div class="layui-inline">
					<label class="layui-form-label">用户地址:</label>
					<div class="layui-input-inline">
						<input type="text" name="address"  placeholder="请输入用户地址" autocomplete="off"
							class="layui-input">
					</div>
				</div>
			</div>
			<div class="layui-form-item">
				<div class="layui-inline">
					<label class="layui-form-label">用户电话:</label>
					<div class="layui-input-inline">
						<input type="text" name="phone" lay-verify="required|phone"  placeholder="请输入用户电话" autocomplete="off"
							class="layui-input">
					</div>
				</div>
				<div class="layui-inline">
					<label class="layui-form-label">用户职位:</label>
					<div class="layui-input-inline">
						<input type="text" name="position"   placeholder="请输入用户职位" autocomplete="off"
							class="layui-input">
					</div>
				</div>
			</div>
			<div class="layui-form-item">
				<div class="layui-inline">
					<label class="layui-form-label">用户性别:</label>
					<div class="layui-input-inline">
						 <input type="radio" name="sex" value="1" checked="checked" title="男">
						 <input type="radio" name="sex" value="0" title="女">
					</div>
				</div>
				<div class="layui-inline">
					<label class="layui-form-label">是否可用:</label>
					<div class="layui-input-inline">
						 <input type="radio" name="available" value="1" checked="checked" title="可用">
						 <input type="radio" name="available" value="0" title="不可用">
					</div>
				</div>
			</div>
			
		</form>
	</div>
	<!-- 添加和修改的弹出层结束 -->
	
	<div style="display: none;padding: 20px" id="selectUserRole">
		<table class="layui-hide" id="roleTable" lay-filter="roleTable"></table>
	</div>
	<script src="${ctx}/resources/layui/layui.js"></script>
	<script type="text/javascript">
		var tableIns
		  layui.extend({
			    dtree: '${ctx}/resources/layui_ext/dtree/dtree'   // {/}的意思即代表采用自有路径，即不跟随 base 路径
			  }).use([ 'jquery', 'layer', 'form', 'table','laydate','dtree' ], function() {
			var $ = layui.jquery;
			var layer = layui.layer;
			var form = layui.form;
			var table = layui.table;
			var laydate=layui.laydate;
			var dtree = layui.dtree;
			
			//绑定时间选择器
			laydate.render({
				elem:'#startTime'
			});
			laydate.render({
				elem:'#endTime'
			})
			
			//渲染数据表格
			tableIns=table.render({
				 elem: '#menuTable'   //渲染的目标对象
			    ,url:'${ctx}/user/loadAllUser.action' //数据接口
			    ,title: '用户数据表'//数据导出来的标题
			    ,toolbar:"#menuToolBar"   //表格的工具条
			    //,height:'full-300'
			    ,cellMinWidth:100 //设置列的最小默认宽度
			    ,page: true  //是否启用分页
			    ,cols: [[   //列表数据
				     {type: 'checkbox', fixed: 'left'}
				     ,{field:'userid', title:'ID',align:'center',width:'80'}
				      ,{field:'realname', title:'用户姓名',align:'center',width:'100'}
				      ,{field:'loginname', title:'登陆名',align:'center',width:'120'}
				      ,{field:'identity', title:'身份证号',align:'center',width:'200'}
				      ,{field:'phone', title:'用户电话',align:'center',width:'150'}
				      ,{field:'address', title:'用户地址',align:'center',width:'160'}
				      ,{field:'sex', title:'性别',align:'center',width:'80',templet:function(d){
				    	  return d.sex=='1'?'<font color=blue>男</font>':'<font color=red>女</font>';
				      }}
				      ,{field:'pwd', title:'密码',align:'center',width:'80',templet:function(d){
				    	  return "******";
				      }}
				      ,{field:'available', title:'是否可用',width:'100',align:'center',templet:function(d){
				    	  return d.available=='1'?'<font color=blue>可用</font>':'<font color=red>不可用</font>';
				      }}
				      ,{fixed: 'right', title:'操作', toolbar: '#userBar', width:260,align:'center'}
				    ]]
				,done:function(data,curr,count){
			    	//不是第一页时如果当前返回的的数据为0那么就返回上一页
			    	console.log(data)
			    	if(data.data.length==0&&curr!=1){
			    		tableIns.reload({
						    page:{ curr:curr-1 }
						});
			    	}
			    }
			})
			$("#doSearch").click(function (){
				var parms = $("#searchFrm").serialize();
				tableIns.reload({
					url:'${ctx}/user/loadAllUser.action?'+parms
					,page:{curr:1}
				})
			})

			//监听行工具事件
		   table.on('tool(menuTable)', function(obj){
			   var data = obj.data; //获得当前行数据
			   var layEvent = obj.event; //获得 lay-event 对应的值（也可以是表头的 event 参数对应的值）
			  if(layEvent === 'del'){ //删除
				 deleteMenu(data);
			     
			   } else if(layEvent === 'edit'){ //编辑
			     //do something
				   layer.msg("修改")
				   openUpdatemenu(obj.data);
			   }else if(layEvent==='resetUserPwd'){
				   resetUserPwd(data);
			   }else if(layEvent === 'selectUserRole'){
				   openSelectUserRole(data);
			   }
			 });
			
			
			
			function resetUserPwd(data){
				layer.confirm('真的重置【'+data.realname+'】这个用户的密码吗', function(index){
			       //向服务端发送删除指令
			       $.post("${ctx}/user/resetUserPwd.action",{userid:data.userid},function(res){
			    	   layer.msg(res.msg);
			       })
			     }); 
			}
			
			//监听头部工具栏事件
			table.on("toolbar(menuTable)",function(obj){
				 switch(obj.event){
				    case 'add':
				      	openAddmenu();
				    break;
				    case 'batchDelete':
				    	deleteBatch();
				    break;
				  };
			})
			
			function deleteMenu(data){
				
				layer.confirm('真的删除【'+data.realname+'】这个用户吗', function(index){
					$.post("${ctx}/user/deleteUser.action",{userid:data.userid},function(res){
						layer.close(index);
						tableIns.reload();
					})
				});
			}
			
			function deleteBatch(){
				var checkStatus = table.checkStatus('menuTable');
				var data = checkStatus.data;
				var params="";
				$.each(data,function(i,item){
			    	if(i==0){
			    		params+="ids="+item.userid;
			    	}else{
			    		params+="&ids="+item.userid;
			    	}
			    });
			    layer.confirm('真的删除选中的这些角色吗', function(index){
				   
			       $.post("${ctx}/user/deleteBatchUser.action",params,function(res){
			    	    layer.msg(res.msg);
			    	    tableIns.reload();
			       })
			     }); 
			}
			
			var mainIndex;
			//打开添加页面
			function openAddmenu(){
				mainIndex = layer.open({
					type:1,
					title:'添加用户',
					content:$("#saveOrUpdateDiv"),
					area:['800px','500px'],
					btnAlign:'c',
					btn:['<div class="layui-icon layui-icon-release">保存</div>','<div class="layui-icon layui-icon-close">关闭</div>'],
					success:function(index){
						$("#dataFrm")[0].reset();
					},
					yes:function(index, layero){
						layer.msg("保存");
						var params = $("#dataFrm").serialize();
						console.log(params);
						$.post("${ctx}/user/addUser.action",params,function(res){
							layer.msg(res.msg);
							layer.close(mainIndex);
							tableIns.reload();
						})
					},
					btn2:function(index, layero){
						layer.msg("关闭");
						return true;
					}
				});
			}
			
			function openUpdatemenu(data){
				mainIndex = layer.open({
					type:1,
					title:'修改用户',
					content:$("#saveOrUpdateDiv"),
					area:['800px','500px'],
					btnAlign:'c',
					btn:['<div class="layui-icon layui-icon-release">保存</div>','<div class="layui-icon layui-icon-close">关闭</div>'],
					success:function(index){
						$("#dataFrm")[0].reset();
						form.val("dataFrm",data);
					},
					yes:function(index, layero){
						layer.msg("保存");
						var params = $("#dataFrm").serialize();
						$.post("${ctx}/user/updateUser.action",params,function(res){
							layer.msg(res.msg);
							layer.close(mainIndex)
							tableIns.reload();
						})
					},
					btn2:function(index, layero){
						layer.msg("关闭");
						return true;
					}
				});
			}
			
			function openSelectUserRole(data){
				var roleTable;
				mainIndex = layer.open({
					type:1,
					title:'分配【'+data.realname+'】的角色',
					content:$("#selectUserRole"),
					area:['550px','600px'],
					btnAlign:'c',
					height:'full',
					btn:['<div class="layui-icon layui-icon-release">确认分配</div>','<div class="layui-icon layui-icon-close">取消分配</div>'],
					success:function(index){
						//渲染数据表格
						roleTable = table.render({
							 elem: '#roleTable'   //渲染的目标对象
						    ,url:'${ctx}/user/initUserRole.action?userid='+data.userid //数据接口
						    ,title: '角色列表'
						    ,cellMinWidth:100 //设置列的最小默认宽度
						    ,cols: [[   //列表数据
							     {type: 'checkbox', fixed: 'left'}
							      ,{field:'roleid', title:'ID',align:'center'}
							      ,{field:'rolename', title:'角色名称',align:'center'}
							      ,{field:'roledesc', title:'角色简介',align:'center'}
							    ]]
						})
					},
					yes:function(index, layero){
						var checkStatus = table.checkStatus("roleTable");
						var roleData = checkStatus.data;
						var params="userid="+data.userid;
						$.each(roleData,function(i,item){
					    	params+="&ids="+item.roleid;
						});
						$.post("${ctx}/user/saveUserRole.action",params,function(obj){
					    	layer.msg(obj.msg);
					    	layer.close(mainIndex);
					    })
					}
				});
			}
		});
		
		function reloadTable(id){
			tableIns.reload({
				url:"${ctx}/menu/loadAllMenu.action?&page=1&limit=10&id="+id
			})
		}
	</script>
</body>
</html>